import java.util.HashMap;

public class Test {
    public static void main(String[] args) {
        //
    }
}

class Solution {
    public int subarraySum(int[] nums, int k) {
        //
        HashMap<Integer, Integer> hash = new HashMap<>();
        //初始化：特殊情况处理
        hash.put(0, 1);
        int ret = 0;
        int sum = 0;
        for(int x: nums){
            sum += x;//计算当前前缀和
            ret += hash.getOrDefault(sum - k, 0);//统计结果
            hash.put(sum, hash.getOrDefault(sum, 0) + 1);//把当前的前缀和丢到哈希表里边

        }
        return ret;

    }
}
